#include <bits/stdc++.h>
using namespace std;
int n;
struct node {
  int w;
  int s;
};
node a[300005];

bool cmp(node x, node y) {
  return x.w + x.s < y.w + y.s;
  // return x.s - y.s < y.w - x.w;
}
long long ans = -1e18; // 默认最小值
int main() {
  cin >> n;
  int mx = 0;
  int k;
  for (int i = 1; i <= n; i++) {
    cin >> a[i].w >> a[i].s;
  }
  sort(a + 1, a + n + 1, cmp); // 排序
  long long sum = 0;
  for (int i = 1; i <= n; i++) { // 模拟，求最大值
    ans = max(ans, sum - a[i].s);
    sum += a[i].w;
  }
  cout << ans;
  return 0;
}